# HMS87C5216

## CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER FOR UR(Universal Remocon) & WIRELESS KEYBOARD

## 1. OVERVIEW

### **1.1 Description**

The HMS87C5216 is an advanced CMOS 8-bit microcontroller with 16K bytes of ROM. The device is one of GMS800 family. The MagnaChip Semicon HMS87C5216 is a powerful microcontroller which provides a highly flexible and cost effective solution to many UR & Keyboard applications. The HMS87C5216 provides the following standard features: 16K bytes of ROM, 320 bytes of RAM, 8-bit timer/ counter, on-chip oscillator, clock circuitry and RC wake up function. 4 chanel ADC, In addition, the HMS87C5216 Series supports power saving modes to reduce power consumption

| Device name | ROM Size | EPROM Size | RAM Size | Operatind<br>Voltage | Package                                |
|-------------|----------|------------|----------|----------------------|----------------------------------------|
| HMS87C5216  | -        | 16K byte   | 320bytes | 2.0 ~ 5.5V           | 28 SOP<br>40 PDIP<br>44 PLCC<br>44 QFP |

## 1.2 Features

- Instruction Cycle Time:
  - 1us at 4MHz
- Programmable I/O pins

|        | 28 PIN | 40 PIN | 44 PIN |
|--------|--------|--------|--------|
| INPUT  | 2      | 2      | 2      |
| OUTPUT | 2      | 2      | 2      |
| I/O    | 22     | 34     | 38     |

#### • Operating Voltage

- 2.0 ~ 5.5 V @ 4MHz
- Timer
  - Timer / Counter ...... 16Bit \* 1ch
  - ........ 16Bit \* 2ch
  - Basic Interval Timer ...... 8Bit \* 1ch
  - Watch Dog Timer ..... 6Bit \* 1ch

- 8 Interrupt sources
  - \* Nested Interrupt control is available.
  - External input: 2
  - Keyscan input
  - Basic Interval Timer
  - Watchdog timer
  - Timer : 3
- Power On Reset
- Power saving Operation Modes
  - STOP
  - SLEEP
- Low Voltage Detection Circuit
- Watch Dog Timer Auto Start (During 1second after Power on Reset)
- 4 CHANEL ADC
- RC TIMER WAKE UP

## 1.3 Development Tools

The HMS87C5216 and HMS87C5216 are supported by a full-featured macro assembler, an in-circuit emulator CHOICE- $Dr^{TM}$ .

| In Circuit Emulators | CHOICE-Dr.              |
|----------------------|-------------------------|
| Assembler            | HME Macro Assembler     |
| OTP Writer           | Single Writer : Sigma   |
| OTP writer           | 4-Gang Writer : Dr.Gang |
| OTP Devices          | HMS87C5216              |

## 2. BLOCK DIAGRAM



### **3. PIN ASSIGNMENT**



## 4. PIN DIAGRAM









## MagnaChip



## **5. PIN FUNCTION**

V<sub>DD</sub>: Supply voltage.

V<sub>SS</sub>: Circuit ground.

**RESET**: Reset the MCU.

 $\mathbf{X}_{IN}\!\!:$  Input to the inverting oscillator amplifier and input to the internal main clock operating circuit.

I

X<sub>OUT</sub>: Output from the inverting oscillator amplifier.

**R00~R07**: R0 is an 8-bit CMOS bidirectional I/O port. R0 pins 1 or 0 written to the Port Direction Register can be used as outputs or inputs.

**R10~R17**: R1 is an 8-bit CMOS bidirectional I/O port. R1 pins 1 or 0 written to the Port Direction Register can be used as outputs or inputs.

In addition, R1 serves the functions of the various following special features.

| Port pin | Alternate function                |
|----------|-----------------------------------|
| R10      | INT1 (External Interrupt input 1) |
| R11      | INT2 (External Interrupt input 2) |
| R12      | T0 (Timer / Counter inpit 0)      |
| R13      | T1 (Timer / Counter inpit 1)      |
| R14      | AN0 (ADC input 0)                 |
| R15      | AN1 (ADC input 1)                 |
| R16      | AN2 (ADC input 2)                 |
| R17      | AN3 (ADC input 3)                 |

**R20~R22**, **R30~R37** : R2 & R3 is a 8-bit CMOS bidirectional I/ O port. Each pins 1 or 0 written to the their Port Direction Register can be used as outputs or inputs.

In addition, R2 serves the functions of the various following special features.

| Port pin | Alternate function           |
|----------|------------------------------|
| R24      | T2 (Timer / Counter inpit 2) |
| R25      | /EC (Event Counter input )   |

**R40~R43** : R4 is 1-bit CMOS bidirectional I/O port. This pin 1 or 0 written to the its Port Direction Register can be used as outputs or inputs.

## MagnaChip•

6.

| PIN Name                                                                                                                   | 1/0 | #  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    | @Reset      | @STOP                      |
|----------------------------------------------------------------------------------------------------------------------------|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------|
| XIN XOUT                                                                                                                   | 1,0 | 2  | Main Clock Input,Output                                                                                                                                                                                                                                                                                                                                                                                                                                        | Oscillation | L, L                       |
| R00/KS0<br>R01/KS1<br>R02/KS2<br>R03/KS3<br>R04/KS4<br>R05/KS5<br>R06/KS6<br>R07/KS7                                       | I/O | 8  | <ul> <li>Each bit of the port can be individually configured as an input or an output by user software</li> <li>Push-pull output</li> <li>CMOS input with pull-up resistor (can be programmable)</li> <li>Programmable Key Scan Input or Open drain output</li> <li>Pull-ups are automatically disabled at output mode</li> </ul>                                                                                                                              | Input       | State of<br>before<br>STOP |
| R10/KS8/INT1<br>R11/KS9/INT2<br>R12/KS10/T0<br>R13/KS11/T1<br>R14/KS12/AN0<br>R15/KS13/AN1<br>R16/KS14/AN2<br>R17/KS15/AN3 | I/O | 8  | <ul> <li>Each bit of the port can be individually configured as an input or an output by user software</li> <li>Push-pull output</li> <li>CMOS input with pull-up resistor (can be programmable)</li> <li>Programmable Key Scan Input or Open drain output</li> <li>Direct Driving of LED (N-TR)</li> <li>Pull-ups are automatically disabled at output mode</li> <li>R1[7:4] is High Driving Capability</li> <li>R1[7:4] is Schmitt Trigger Input.</li> </ul> | Input       | State of<br>before<br>STOP |
| R2[3:0]<br>R24/T2<br>R25/EC0<br>R2[7:6]<br>R3[7:0]<br>R4[5:0]                                                              | I/O | 22 | <ul> <li>Each bit of the port can be individually configured as an input or an output by user software</li> <li>Push-pull output</li> <li>CMOS input with pull-up resistor (can be programmable)</li> <li>Programmable Open drain output</li> <li>Direct Driving of LED (N-TR)</li> <li>Pull-ups are automatically disabled at output mode</li> </ul>                                                                                                          | Input       | State of<br>before<br>STOP |
| RESETB                                                                                                                     | I   | 1  | Resetb Pin                                                                                                                                                                                                                                                                                                                                                                                                                                                     | L           | H                          |
| REMOUT                                                                                                                     | 0   | 1  | Remocon Output                                                                                                                                                                                                                                                                                                                                                                                                                                                 | L           | L                          |
| VDD                                                                                                                        | -   | 1  | Power Supply                                                                                                                                                                                                                                                                                                                                                                                                                                                   | VDD         | VDD                        |
| VSS                                                                                                                        | -   | 1  | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                         | VSS         | VSS                        |

## 7. PORT STRUCTURES

## • RESET



• Xin, Xout







• RA0/EC0

#### HMS87C5216









## • RA1/AN1 ~ RA7/AN7

## 8. ELECTRICAL CHARACTERISTICS (HMS87C5216/GMS81C1408)

#### 8.1 Absolute Maximum Ratings

| Supply voltage0.3 to +7.0 V                                     | V |
|-----------------------------------------------------------------|---|
| Storage Temperature40 to +125 °C                                | 2 |
| aximum current out of V <sub>SS</sub> pin TBD mA                | ł |
| Maximum current into V <sub>DD</sub> pin TBD mA                 | ł |
| Maximum current sunk by (I <sub>OL</sub> per I/O Pin) TBD mA    | ł |
| Maximum output current sourced by (I <sub>OH</sub> per I/O Pin) |   |
|                                                                 | ł |
| Maximum current ( $\Sigma I_{OL}$ )                             | ł |
| Maximum current (ΣI <sub>OH</sub> ) TBDmA                       | ł |

**Note:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### 8.2 Recommended Operating Conditions

| Demonster             | Oh.a.l           | 0                         | Specifications | 11   |      |
|-----------------------|------------------|---------------------------|----------------|------|------|
| Parameter             | Symbol           | Condition                 | Min.           | Max. | Unit |
| Supply Voltage        | V <sub>DD</sub>  | f <sub>XIN</sub> =4MHz    | 2.0            | 5.5  | V    |
| Operating Frequency   | f <sub>XIN</sub> | V <sub>DD</sub> =2.0~5.5V | 1              | 4    | MHz  |
| Operating Temperature | T <sub>OPR</sub> | V <sub>DD</sub> =2.0~5.5V | -20            | 85   | °C   |

#### 8.3 A/D Converter Characteristics

(T<sub>A</sub>=25° C, V<sub>SS</sub>=0V, V<sub>DD</sub>=3.072V @f<sub>XIN</sub>=4MHz)

| Parameter                               | Cumhal            | Condition              | S                    | Unit  |                      |      |  |
|-----------------------------------------|-------------------|------------------------|----------------------|-------|----------------------|------|--|
| Parameter                               | Symbol            | Condition              | Min.                 | Тур.  | Max.                 | Unit |  |
| Analog Input Voltage Range              | V <sub>AIN</sub>  | -                      | V <sub>SS-</sub> 0.3 | -     | V <sub>DD</sub> +0.3 | V    |  |
| Current Following Between AVdd and AVss | IAVdd             | -                      | -                    | -     | 200                  | uA   |  |
| Overall Accuracy                        | N <sub>ACC</sub>  | -                      | -                    | ±1.0  | ±2.0                 | LSB  |  |
| Non-Linearity Error                     | N <sub>NLE</sub>  | -                      | -                    | ±1.0  | ±2.0                 | LSB  |  |
| Differential Non-Linearity Error        | N <sub>DNLE</sub> | -                      | -                    | ±1.0  | ±2.0                 | LSB  |  |
| Zero Offset Error                       | N <sub>ZOE</sub>  |                        | -                    | ±0.5  | ±1.5                 | LSB  |  |
| Full Scale Error                        | N <sub>FSE</sub>  |                        | -                    | ±0.25 | ±0.5                 | LSB  |  |
| Gain Error                              | N <sub>NLE</sub>  |                        | -                    | ±1.0  | ±1.5                 | LSB  |  |
| Conversion Time                         | T <sub>CONV</sub> | f <sub>XIN</sub> =4MHz | -                    | -     | 30                   | uS   |  |

#### **8.4 DC Electrical Characteristics**

 $(T_{A}=-20 - 85^{\circ}C \text{ for HMS87C5216}/1408 \text{ or } T_{A}=-40 - 85^{\circ}C \text{ for HMS87C5216E}/1408E, V_{DD}=2.2 - 5.5V, V_{SS}=0V),$ 

| Parameter Symb     | Symbol           | Pin                     | Condition | Specifications      |      |          | Unit |
|--------------------|------------------|-------------------------|-----------|---------------------|------|----------|------|
|                    | Symbol           | Pin                     |           | Min.                | Тур. | Max.     | Unit |
| Input High Voltage | V <sub>IH1</sub> | X <sub>IN</sub> , RESET |           | 0.8 V <sub>DD</sub> | -    | $V_{DD}$ | V    |

| Deveryorter                    | oh.e.l             | Dire                                | O a malifi a m                                | Sp                 | 11   |                    |      |
|--------------------------------|--------------------|-------------------------------------|-----------------------------------------------|--------------------|------|--------------------|------|
| Parameter                      | Symbol             | Pin                                 | Condition                                     | Min.               | Тур. | Max.               | Unit |
| Input High Voltage             | V <sub>IH1</sub>   | RESET,XIN,INT1,IN<br>T2,EC0,R1<7:4> |                                               | 0.8V <sub>DD</sub> | -    | V <sub>DD</sub>    | V    |
|                                | V <sub>IH2</sub>   | R0,R1,R2,R3,R4                      |                                               | 0.7V <sub>DD</sub> | -    | V <sub>DD</sub>    | V    |
| Input Low Voltage              | V <sub>IL1</sub>   | RESET,XIN,INT1,IN<br>T2,EC0,R1<7:4> |                                               | 0                  | -    | 0.2V <sub>DD</sub> | V    |
|                                | V <sub>IL2</sub>   | R0,R1,R2,R3,R4                      |                                               | 0                  | -    | 0.3V <sub>DD</sub> | V    |
| Input High<br>Leakage Current  | I <sub>IH</sub>    | R0,R1,R2,R3,R4<br>RESETB            | V <sub>IH</sub> =VDD                          | -                  | -    | 1.0                | μA   |
| Input Low<br>Leakage Current   | IIL                | R0,R1,R2,R3,R4                      | V <sub>IL</sub> =0V                           | -                  | -    | -1.0               | μA   |
|                                | V <sub>OH1</sub>   | R0,R1<3:0>,R2,R3,<br>R4             | loh1=-0.8mA,VDD=3V                            | VDD-0.4            | -    | -                  | V    |
| Output High Voltage            | V <sub>OH2</sub>   | R1<7:0>,                            | Ioh2=-2.0mA,VDD=3V                            | VDD-0.4            | -    | -                  | V    |
|                                | V <sub>OH3</sub>   | XOUT                                | loh3=-50uA,VDD=3V                             | VDD-0.5            | -    | -                  | V    |
| Output Low Voltage             | V <sub>OL1</sub>   | R0,R1<3:0>,R2,R3,<br>R4             | I <sub>OL</sub> =5mA,V <sub>DD</sub> =3V      | -                  | -    | 0.8                | V    |
|                                | V <sub>OL2</sub>   | XOUT                                | I <sub>OL</sub> =50uA,V <sub>DD</sub> =3V     | -                  | -    | 0.5                | V    |
| Output High<br>Leakage Current | I <sub>IOHL</sub>  | R0,R1,R2,R3,R4                      | V <sub>OH</sub> =VDD                          | -                  | -    | 1.0                | μA   |
| Output Low<br>Leakage Current  | I <sub>IOLL</sub>  | R0,R1,R2,R3,R4                      | V <sub>OL</sub> =0V                           | -                  | -    | -1.0               | μA   |
| Output High Current            | I <sub>ОН</sub>    | REMOUT                              | VDD=3V,VOH=2.0V                               | -20                | -    | -5                 | mA   |
| Output Low Current             | I <sub>OL</sub>    | REMOUT                              | VDD=3V,VOL=1.0V                               | -0.5               | -    | 3                  | mA   |
| Input Pull-up                  | I <sub>P</sub>     | R0,R1,R2,R3,R4<br>RESETB            | V <sub>DD</sub> =3V                           | 50                 | 100  | 200                | κ    |
| Hysteresis                     | V <sub>T</sub>     | Hysteresis Input <sup>1</sup>       | V <sub>DD</sub> =5V                           | 0.5                | -    | -                  | V    |
| Feed Back Resistor             | RF!                | Main OSC Feedback<br>Resistor       | V <sub>DD</sub> =3.0V, f <sub>XIN</sub> =4MHz | 0.2                | -    | 1.0                |      |
|                                | I <sub>DD</sub>    | Active Mode                         | V <sub>DD</sub> =4.0V                         | -                  | 4.0  | 10                 | mA   |
|                                | טטי                |                                     | V <sub>DD</sub> =2.0V                         | -                  | 2.4  | 6                  | mA   |
| Supply Currnet                 | I <sub>sleep</sub> | Sleep Mode                          | V <sub>DD</sub> =4.0V                         | -                  | 2.0  | 3.0                | mA   |
| Cappiy Currici                 | ·sieep             |                                     | V <sub>DD</sub> =2.0V                         | -                  | 1.0  | 2.0                | mA   |
|                                | I <sub>stop</sub>  | Stop Mode,Osc Stop                  | V <sub>DD</sub> =4.0V                         | -                  | 5.0  | 30                 | μA   |
|                                | ·stop              |                                     | V <sub>DD</sub> =2.0V                         | -                  | 3.0  | 25                 | μA   |

#### **8.5 AC Characteristics**

 $(T_{A}=-20 \sim 85^{\circ} \text{C for HMS87C5216}/1408 \text{ or } T_{A}=-40 \sim 85^{\circ} \text{C for HMS87C5216E}/1408\text{E}, \text{V}_{\text{DD}}=5 \text{V}\pm10\%, \text{V}_{\text{SS}}=0 \text{V})$ 

| <b>D</b>                                     |                                    | <b>D</b>                           | S    | 11   |      |                  |
|----------------------------------------------|------------------------------------|------------------------------------|------|------|------|------------------|
| Parameter                                    | Symbol                             | Pins                               | Min. | Тур. | Max. | Unit             |
| Operating Frequency                          | f <sub>MCP</sub>                   | X <sub>IN</sub>                    | 1    | -    | 4    | MHz              |
| Systemp Clock Cycle Time                     | t <sub>SYS</sub>                   | -                                  | 0.5  | -    | 2.0  | uS               |
| Oscillation Stabilizing<br>Time(4MHz)        | t <sub>MST!</sub>                  | X <sub>IN</sub> , X <sub>OUT</sub> | -    | -    | 20   | mS               |
| External Clock "H" or "L" Pulse<br>Width     | t <sub>CPW</sub>                   | X <sub>IN</sub>                    | 80   |      |      | nS               |
| External Clock Transition Time               | t <sub>RCP</sub> ,t <sub>FCP</sub> | X <sub>IN</sub>                    | -    | -    | 20   | nS               |
| Interrupt Input Pulse Width                  | t <sub>IVV</sub>                   | INT1,INT2                          | 2    | -    |      | t <sub>SYS</sub> |
| RESETB Input Pulse "L" Width                 | t <sub>RST</sub>                   | RESETB                             | 8    | -    | -    | t <sub>SYS</sub> |
| Event Couter Input "H" or "L"<br>Pulse Width | t <sub>TCW</sub>                   | ECo                                | 2    | -    | -    | t <sub>SYS</sub> |
| Event Couter Transition Time                 | t <sub>REC</sub> ,t <sub>FEC</sub> | ECo                                | 0    | -    | 20   | nS               |



Figure 8-1 Timing Chart

### 9. MEMORY ORGANIZATION

The HMS87C5216 have separate address spaces for Program memory and Data Memory. Program memory can only be read, not written to. It can be up to 16K bytes of Program memory.

#### 9.1 Registers

This device has six registers that are the Program Counter (PC), a Accumulator (A), two index registers (X, Y), the Stack Pointer (SP), and the Program Status Word (PSW). The Program Counter consists of 16-bit register.



Figure 9-1 Configuration of Registers

Accumulator: The Accumulator is the 8-bit general purpose register, used for data operation such as transfer, temporary saving, and conditional judgement, etc.

The Accumulator can be used as a 16-bit register with Y Register as shown below.





**X**, **Y Registers**: In the addressing mode which uses these index registers, the register contents are added to the specified address, which becomes the actual address. These modes are extremely effective for referencing subroutine tables and memory tables. The index registers also have increment, decrement, comparison and data transfer functions, and they can be used as simple accumulators.

**Stack Pointer**: The Stack Pointer is an 8-bit register used for occurrence interrupts and calling out subroutines. Stack Pointer Data memory can be read and written to up to 320 bytes including the stack area.

identifies the location in the stack to be accessed (save or restore).

Generally, SP is automatically updated when a subroutine call is executed or an interrupt is accepted. However, if it is used in excess of the stack area permitted by the data memory allocating configuration, the user-processed data may be lost.

The stack can be located at any position within  $100_{\rm H}$  to  $17F_{\rm H}$  of the internal data memory. The SP is not initialized by hardware, requiring to write the initial value (the location with which the use of the stack starts) by using the initialization routine. Normally, the initial value of " $17F_{\rm H}$ " is used.



**Note:** The Stack Pointer must be initialized by software because its value is undefined after RESET. Example: To initialize the SP

LDX #07FH TXSP ; SP  $\leftarrow$ 7F<sub>H</sub>

**Program Counter**: The Program Counter is a 16-bit wide which consists of two 8-bit registers, PCH and PCL. This counter indicates the address of the next instruction to be executed. In reset state, the program counter has reset routine address ( $PC_H:OFF_H$ ,  $PC_L:OFE_H$ ).

**Program Status Word**: The Program Status Word (PSW) contains several bits that reflect the current state of the CPU. The PSW is described in Figure 9-3. It contains the Negative flag, the Overflow flag, the Break flag the Half Carry (for BCD operation), the Interrupt enable flag, the Zero flag, and the Carry flag.

#### [Carry flag C]

This flag stores any carry or borrow from the ALU of CPU after an arithmetic operation and is also changed by the Shift Instruction or Rotate Instruction.

#### [Zero flag Z]

This flag is set when the result of an arithmetic operation or data transfer is "0" and is cleared by any other result.

## MagnaChip=



#### Figure 9-3 PSW (Program Status Word) Register

#### [Interrupt disable flag I]

This flag enables/disables all interrupts except interrupt caused by Reset or software BRK instruction. All interrupts are disabled when cleared to "0". This flag immediately becomes "0" when an interrupt is served. It is set by the EI instruction and cleared by the DI instruction.

#### [Half carry flag H]

After operation, this is set when there is a carry from bit 3 of ALU or there is no borrow from bit 4 of ALU. This bit can not be set or cleared except CLRV instruction with Overflow flag (V).

#### [Break flag B]

This flag is set by software BRK instruction to distinguish BRK from TCALL instruction with the same vector address.

#### [Overflow flag V]

This flag is set to "1" when an overflow occurs as the result of an arithmetic operation involving signs. An overflow occurs when the result of an addition or subtraction exceeds  $+127(7F_H)$  or  $-128(80_H)$ . The CLRV instruction clears the overflow flag. There is no set instruction. When the BIT instruction is executed, bit 6 of memory is copied to this flag.

#### [Negative flag N]

This flag is set to match the sign bit (bit 7) status of the result of a data or arithmetic operation. When the BIT instruction is executed, bit 7 of memory is copied to this flag.

#### [Direct page flag G]

This flag assigns RAM page for direct addressing mode. In the direct addressing mode, addressing area is from zero page 00 to FF when this flag is 0. If it is set to 1, addressing area is 1 page. It is set by instruction and cleared by CLRG.

#### 9.2 Program Memory

A 16-bit program counter is capable of addressing up to 64K bytes, but these devices have 16K bytes program memory space only physically implemented. Accessing a location above  $\text{FFF}_{H}$  will cause a wrap-around to  $0000_{H}$ .

Figure 9-4, shows a map of Program Memory. After reset, the CPU begins execution from reset vector which is stored in address  $FFFE_H$  and  $FFFF_H$  as shown in Figure 9-5.

As shown in Figure 9-4, each area is assigned a fixed location in Program Memory. Program Memory area contains the user program.



Figure 9-4 Program Memory Map

Page Call (PCALL) area contains subroutine program to reduce program byte length by using 2 bytes PCALL instead of 3 bytes CALL instruction. If it is frequently called, it is more useful to save program byte length.

Table Call (TCALL) causes the CPU to jump to each TCALL address, where it commences the execution of the service routine. The Table Call service area spaces 2-byte for every TCALL:  $0FFC0_{\rm H}$  for TCALL15,  $0FFC2_{\rm H}$  for TCALL14, etc., as shown in Figure 9-6.

Example: Usage of TCALL



The interrupt causes the CPU to jump to specific location, where it commences the execution of the service routine. The External interrupt 0, for example, is assigned to location  $0FFFA_H$ . The interrupt service locations spaces 2-byte interval:  $0FFF8_H$  and  $0FFF9_H$  for External Interrupt 1,  $0FFFA_H$  and  $0FFFB_H$  for External Interrupt 0, etc.

As for the area from  $0FF00_H$  to  $0FFFF_H$ , if any area of them is not going to be used, its service location is available as general purpose Program Memory.

| Address            | Vector Area Memory                    |
|--------------------|---------------------------------------|
| 0FFE0 <sub>H</sub> | -                                     |
| E2                 | -                                     |
| E4                 | ADC Interrupt Vector Area             |
| E6                 | RC WT Interrupt Vector Area           |
| E8                 | BIT Interrupt Vector Area             |
| EA                 | WDT Interrupt Vector Area             |
| EC                 | -                                     |
| EE                 | Timer/Counter 2 Interrupt Vector Area |
| F0                 | Timer/Counter 1 Interrupt Vector Area |
| F2                 | Timer/Counter 0 Interrupt Vector Area |
| F4                 | -                                     |
| F6                 | EXT2 Interrupt Vector Area            |
| F8                 | EXT1 Interrupt Vector Area            |
| FA                 | KEY SCAN Interrupt Vector Area        |
| FC                 | -                                     |
| FE                 | RESET Vector Area                     |

NOTE: "-" means reserved area.

Figure 9-5 Interrupt Vector Area

## MagnaChip



Example: The usage software example of Vector address and the initialize part.

ORG OFFEOH

DW NOT USED; (OFFEO) NOT\_USED; (0FFE2) ADC\_INT; (0FFE4) A/D Interface RC\_WT\_INT; (0FFE6) RC WAKE UP Timer DW DW DW BIT\_INT; (OFFE8) BIT Timer WDT\_INT; (OFFEA) WDT DW DW WDT\_INT; (OFFEA) WDT NOT\_USED; (OFFEC) TMR2\_INT; (OFFEE) Timer-2 TMR1\_INT; (OFFF0) Timer-1 TMR0\_INT; (OFFF2) Timer-0 NOT\_USED; (OFFF4) DW DW DW DW DW EXT2\_INT; (OFFF6) External2 EXT1\_INT; (OFFF8) External1 DW DW KEY SCAN; (OFFFA) Key Scan NOT USED; (OFFFC) RESET; (OFFFE) Reset DW DW DW

ORG 0F000H

:

| ; ************************************ |                                    |                                                                                                                                  |  |  |  |
|----------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| RESET:                                 | DI<br>LDX                          | ;Disable All Interrupts<br>#0                                                                                                    |  |  |  |
| RAM_CLR:                               | STA<br>CMPX                        |                                                                                                                                  |  |  |  |
| ;                                      | LDX<br>TXSP                        | #07FH;Stack Pointer Initialize                                                                                                   |  |  |  |
| ;                                      | CALL                               | INITIAL;                                                                                                                         |  |  |  |
| ,                                      | LDM<br>LDM<br>LDM<br>LDM<br>:<br>: | R1, #0;Normal Port A<br>R1DD,#1000_0010B;Normal Port Direction<br>R2, #0;Normal Port B<br>R2DD,#1000_0010B;Normal Port Direction |  |  |  |

#### 9.3 Data Memory

Figure 9-7 shows the internal Data Memory space available. Data Memory is divided into two groups, a user RAM (including Stack) and control registers.



Figure 9-7 Data Memory Map

#### **User Memory**

The HMS87C5216 has  $330 \times 8$  bits for the user memory (RAM).

#### **Control Registers**

The control registers are used by the CPU and Peripheral function blocks for controlling the desired operation of the device. Therefore these registers contain control and status bits for the interrupt system, the timer/ counters, analog to digital converters and I/O ports. The control registers are in address range of  $0C0_H$  to  $0FF_H$ .

Note that unoccupied addresses may not be implemented on the chip. Read accesses to these addresses will in general return random data, and write accesses will have an indeterminate effect.

More detailed informations of each register are explained in each peripheral section.

**Note:** Write only registers can not be accessed by bit manipulation instruction. Do not use read-modify-write instruction. Use byte manipulation instruction.

Example; To write at CKCTLR

LDM CKCTLR, #09H ; Divide ratio ÷16

Note: Several names are given at same address. Refer to-

| Address                                                                                                                                                      | Symbol                                                                                                                                                                     | R/W                                                                                        | RESET<br>Value                                                                                                                                                                                             | Addressing<br>mode                                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address                                                                                                                                                      | Symbol                                                                                                                                                                     | R/W                                                                                        | RESET<br>Value                                                                                                                                                                                             | Addressing<br>mode                                                                                                                                                        |
| 0C0H<br>0C1H<br>0C2H<br>0C3H<br>0C4H<br>0C5H<br>0C6H<br>0C7H<br>0C7H<br>0C7H<br>0C8H<br>0C9H<br>0CAH<br>0CBH<br>0CCH<br>0CCH<br>0CCH                         | R0<br>R0DR<br>R1<br>R1DR<br>R2<br>R2DR<br>TMR1<br>CKCTLR<br>BITR<br>WDTR<br>PSR<br>RCWTR<br>IESR<br>IENL<br>IRQL<br>IENH<br>IRQH                                           | R/W<br>W<br>R/W<br>W<br>W<br>W<br>W<br>W<br>W<br>R/W<br>R/W<br>R/W<br>R/W                  | Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>11_0111<br>0000_0000<br>-000_1111<br>00_0000<br>00_000-<br>-0000<br>0000<br>000_000-<br>000000-                              | byte, bit <sup>1</sup><br>byte <sup>2</sup><br>byte, bit<br>byte<br>byte, bit<br>byte<br>byte<br>byte<br>byte<br>byte,bit<br>byte,bit<br>byte,bit<br>byte,bit<br>byte,bit |
| 0D0H<br>0D1H<br>0D2H<br>0D3H<br>0D4H<br>0D5H<br>0D5H<br>0D6H<br>0D6H<br>0D7H<br>0D8H<br>0D8H<br>0D9H<br>0D9H<br>0D9H<br>0D0H<br>0DCH<br>0DCH<br>0DCH<br>0DCH | TM0<br>TM1<br>TM2<br>T0HMD<br>T0HLD<br>T0HLD<br>T0LC<br>T0LMD<br>T0LC<br>T0LLD<br>T1HD<br>T1C<br>T1LD<br>T1C<br>T1LD<br>T2C<br>T2D<br>TM01<br>KSR0<br>KSR1<br>R10D<br>R20D | R/W<br>R/W<br>W<br>W<br>R<br>W<br>R<br>W<br>R<br>W<br>R<br>W<br>R<br>W<br>W<br>W<br>W<br>W | 0000_0000<br>0000000<br>Undefined<br>Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>0000_0000<br>0000_0000<br>0000_0000 | byte, bit<br>byte, bit<br>byte, bit<br>byte<br>byte<br>byte<br>byte<br>byte<br>byte<br>byte<br>byt                                                                        |
| 0E0H<br>0E1H<br>0E5H<br>0E5H<br>0E6H<br>0E7H<br>0E8H<br>0EEH<br>0EFH                                                                                         | R3OD<br>R4OD<br>R0OD<br>R3<br>R3DR<br>R4<br>R4DR<br>TMR2<br>LVDR                                                                                                           | W<br>W<br>R/W<br>R/W<br>R<br>R<br>R<br>R<br>R                                              | 0000_0000<br>00_0000<br>Undefined<br>0000_0000<br>Undefined<br>00_0000<br>0000_0000<br>00-                                                                                                                 | byte<br>byte<br>byte,bit<br>byte,bit<br>byte,bit<br>byte<br>byte<br>byte                                                                                                  |

#### **Table 9-1 Control Registers**

#### HMS87C5216

| 0F0H<br>0F4H<br>0F5H<br>0F6H<br>0F7H<br>0F8H<br>0F9H | SMR<br>ADMR<br>ADDR<br>KRL0<br>KRL1<br>R0PU<br>R1PU | W<br>R/W<br>R<br>W<br>W<br>W | 0<br>-000_0001<br>Undefined<br>0000_0000<br>0000_0000<br>0000_0000<br>0000_0000 | byte, bit<br>byte, bit<br>byte<br>byte<br>byte<br>byte |
|------------------------------------------------------|-----------------------------------------------------|------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------|
| 0FAH                                                 | R2PU                                                | W                            | 0000_0000                                                                       | byte                                                   |
| 0FBH<br>0FCH                                         | R3PU<br>R4PU                                        | W<br>W                       | 0000_0000<br>00_0000                                                            | byte<br>byte                                           |

#### Table 9-1 Control Registers

- 1. "byte, bit" means that register can be addressed by not only bit but byte manipulation instruction.
- 2. "byte" means that register can be addressed by only byte manipulation instruction. On the other hand, do not use any read-modify-write instruction such as bit manipulation for clearing bit.

## MagnaChip•

#### below table.

#### **Stack Area**

The stack provides the area where the return address is saved before a jump is performed during the processing routine at the execution of a subroutine call instruction or the acceptance of an interrupt.

When returning from the processing routine, executing the subroutine return instruction [RET] restores the contents of the program counter from the stack; executing the interrupt return instruction [RETI] restores the contents of the program counter and flags.

The save/restore locations in the stack are determined by the stack pointed (SP). The SP is automatically decreased after the saving, and increased before the restoring. This means the value of the SP indicates the stack location number for the next save.

#### 9.4 Addressing Mode

The HMS87C5216 and GMS81C1408 uses six addressing modes;

- Register addressing
- Immediate addressing
- Direct page addressing
- Absolute addressing
- Indexed addressing
- · Register-indirect addressing

#### (1) Register Addressing

Register addressing accesses the A, X, Y, C and PSW.

#### (2) Immediate Addressing →#imm

In this mode, second byte (operand) is accessed as a data immediately.

#### Example:

0435 ADC #35H



#### E45535 LDM 35H,#55H



#### (3) Direct Page Addressing $\rightarrow$ dp

In this mode, a address is specified within direct page. Example;

C535 LDA 35H ;A ←RAM[35H]



#### (4) Absolute Addressing $\rightarrow$ !abs

Absolute addressing sets corresponding memory data to Data, i.e. second byte(Operand I) of command becomes lower level address and third byte (Operand II) becomes upper level address. With 3 bytes command, it is possible to access to whole memory area.

ADC, AND, CMP, CMPX, CMPY, EOR, LDA, LDX, LDY, OR, SBC, STA, STX, STY

Example;

0735F0 ADC !0F035H ;A ←ROM[0F035H]



The operation within data memory (RAM) ASL, BIT, DEC, INC, LSR, ROL, ROR

Example; Addressing accesses the address  $0135_{\text{H}}$ .

| 983500 | INC | !0035H | ;A ←RAM[035H] |
|--------|-----|--------|---------------|



#### (5) Indexed Addressing

#### X indexed direct page (no offset) $\rightarrow$ {X}

In this mode, a address is specified by the X register.

ADC, AND, CMP, EOR, LDA, OR, SBC, STA, XMA Example; X=15 $_{\rm H}$ 

D4 LDA  $\{X\}$ ; ACC $\leftarrow$ RAM[X].



#### X indexed direct page, auto increment $\rightarrow$ {X}+

In this mode, a address is specified within direct page by the X register and the content of X is increased by 1.

LDA, STA

Example; X=35<sub>H</sub>

DB LDA {X}+



#### X indexed direct page (8 bit offset) $\rightarrow$ dp+X

This address value is the second byte (Operand) of command plus the data of X-register. And it assigns the memory in Direct page.

ADC, AND, CMP, EOR, LDA, LDY, OR, SBC, STA STY, XMA, ASL, DEC, INC, LSR, ROL, ROR

#### Example; X=015<sub>H</sub>

C645 LDA 45H+X



## MagnaChip•

#### Y indexed direct page (8 bit offset) →dp+Y

This address value is the second byte (Operand) of command plus the data of Y-register, which assigns Memory in Direct page.

This is same with above (2). Use Y register instead of X.

#### Y indexed absolute -Jabs+Y

Sets the value of 16-bit absolute address plus Y-register data as Memory. This addressing mode can specify memory in whole area.

#### Example; Y=55<sub>H</sub>

D500FA LDA !OFA00H+Y



#### (6) Indirect Addressing

#### Direct page indirect $\rightarrow$ [dp]

Assigns data address to use for accomplishing command which sets memory data(or pair memory) by Operand. Also index can be used with Index register X,Y.

JMP, CALL

Example;

#### 3F35 JMP [35H]



#### X indexed indirect $\rightarrow$ [dp+X]

Processes memory data as Data, assigned by 16-bit pair memory which is determined by pair data [dp+X+1][dp+X] Operand plus X-register data in Direct page.

ADC, AND, CMP, EOR, LDA, OR, SBC, STA

Example; X=10<sub>H</sub>

1625 ADC [25H+X]



#### Y indexed indirect $\rightarrow$ [dp]+Y

Processes memory data as Data, assigned by the data [dp+1][dp] of 16-bit pair memory paired by Operand in Direct page plus Y-register data.

ADC, AND, CMP, EOR, LDA, OR, SBC, STA

Example; Y=10<sub>H</sub>

1725 ADC [25H]+Y

#### Absolute indirect $\rightarrow$ [!abs]

The program jumps to address specified by 16-bit absolute address.

JMP

Example;

1F25E0 JMP [!0C025H]





## 10. I/O PORTS

The GMS87C5216 has 38 I/O ports which are PORT0(8 I/O), PORT1 (8 I/O), PORT2 (8 I/O), PORT3 (8 I/O), PORT4 (6 I/O). Pull-up resistor of each port can be selectable by program. Each port contains data direction register which controls I/O and data register which stores port data

#### 10.1 R0 Ports

R0 is an 8-bit CMOS bidirectional I/O port (address  $0C0_H$ ). Each I/O pin can independently used as an input or an output through the R0DD register (address  $0C1_H$ ).

R0 has internal pull-ups that is independently connected or disconnected by R0PC. The control registers for R0 are shown below.

|                                   | ADDRESS : 0C0 <sub>H</sub><br>RESET VALUE : Undefined<br>R02 R01 R00                                   |
|-----------------------------------|--------------------------------------------------------------------------------------------------------|
| R0 Direction Register (W)         | ADDRESS : 0C1 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Port Direction<br>0: Input<br>1: Output |
| R0 Pull-up Selection Register (W) | ADDRESS :0F8 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>                                         |
| R0 Open drain Assign Register (W) | ADDRESS :0E4 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>                                         |

#### (1) R0 I/O Data Direction Register (R0DD)

R0 I/O Data Direction Register (R0DD) is 8-bit register, and can assign input state or output state to each bit. If R0DD is ``1``, port R0 is in the output state, and if ``0``, it is in the input state. R0DD is write-only register. Since R0DD is initialized as ``00 h`` in reset state, the whole port R0 becomes input state.

#### (2) R0 Data Register (R0)

R0 data register (R0) is 8-bit register to store data of port R0. When set as the output state by R0DD, and data is written in R0, data is outputted into R0 pin. When set as the input state, input state of pin is read. The initial value of R0 is unknown in reset state.

#### (3) R0 Open drain Assign Register (R0ODC)

R0 Open Drain Assign Register (R0ODC) is 8bit register, and can assign R0 port as open drain output port each bit, if corresponding port is selected as output. If R0ODC is selected as ``1``, port R0 is open drain output, and if selected as ``0``, it is push-pull output. R0ODC is write-only register and initialized as ``00 h`` in reset state.

#### (4) R0 Pull-up Resistor Control Register (R0PC)

R0 pull-up resistor control register (R0PC) is 8-bit register and can control pull-up on or off each bit, if corresponding port is selected as input. If R0PC is selected as ``1``, pull-up ia disabled and if selected as ``0``, it is enabled. R0PC is write-only register and initialized as ``00 h`` in reset state. The pull-up is automatically disabled, if corresponding port is selected as output.

## 10.2 R1 Ports

R1 is an 8-bit CMOS bidirectional I/O port (address  $0C2_{\rm H}$ ). Each I/O pin can independently used as an input or an output through the R1DD register (address  $0C3_{\rm H}$ ).

R1 has internal pull-ups that is independently connected or disconnected by register R1PC. The control registers for R1 are shown below.



#### (1) R1 I/O Data Direction Register (R1DD)

R1 I/O Data Direction Register (R1DD) is 8-bit register, and can assign input state or output state to each bit. If R1DD is ``1``, port R1 is in the output state, and if ``0``, it is in the input state. R1DD is write-only register. Since R1DD is initialized as ``00 h`` in reset state, the whole port R1 becomes input state.

#### (2) R1 Data Register (R1)

R1 data register (R1) is 8-bit register to store data of port R1. When set as the output state by R1DD, and data is written in R1, data is outputted into R1 pin. When set as the input state, input state of pin is read. The initial value of R1 is unknown in reset state.

#### (3) R1 Mode Register (PMR1)

R1 Port Mode Register (PMR1) is 8-bit register, and can assign the selection mode for each bit. When set as ``0``, corresponding bit of PMR1 acts as port R1 selection mode, and when set as ``1``, it becomes function selection mode.

PMR1 is write-only register and initialized as ``00 h`` in reset state. Therefore, becomes Port selection mode. Port R1 can be I/ O port by manipulating each R1DD bit, if corresponding PMR1 bit is selected as ``0``.

| Pin Name   | PMR1 | Selection<br>Mode | Remarks      |  |
|------------|------|-------------------|--------------|--|
| -          |      |                   |              |  |
| -          |      |                   |              |  |
| 500        | 0    | R25(I/O)          | -            |  |
| EC0        | 1    | EC0(I)            | EVENT COUNT0 |  |
| T2         | 0    | R24(I/O)          | -            |  |
| 12         | 1    | T2(O)             | TIMER2       |  |
| <b>T</b> 4 | 0    | R13 (I/O)         | -            |  |
| T1         | 1    | T1(O)             | TIMER1       |  |
| то         | 0    | R12 (I/O)         | -            |  |
| ТО         | 1    | T0(O)             | TIMER0       |  |
| INT2       | 0    | R11 (I/O)         | -            |  |
| INIZ       | 1    | INT2(I)           | EXT INT2     |  |
| INITA      | 0    | R10(I/O)          | -            |  |
| INT1       | 1    | INT1(I)           | EXT INT1     |  |

Table 10-1 Selection mode of PMR1

#### (4) R1 Pull-up Resistor Control Register (R1PC)

R1 pull-up resistor control register (R1PC) is 8-bit register and can control pull-up on or off each bit, if corresponding port is selected as input. If R1PC is selected as ``1``, pull-up ia disabled and if selected as ``0``, it is enabled. R1PC is write-only register and initialized as ``00 h`` in reset state. The pull-up is automatically disabled, if corresponding port is selected as output.

#### 10.3 R2 Port

R2 is an 8-bit CMOS bidirectional I/O port (address  $0C4_{H}$ ). Each I/O pin can independently used as an input or an output through the R2DD register (address  $0C5_{H}$ ).

R2 has internal pujll-ups that is independently connected or disconnected by R2PC (address  $0FA_H$ ). The control registers for R2 are shown as below.

## MagnaChip=

| R2 Data R<br>R2    | register (R/W)<br>R27 R26 R25 R24 R2 | ADDRESS : 0C4 <sub>H</sub><br>RESET VALUE : Undefined<br>23 R22 R21 R20                                               |
|--------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| R2 Directi<br>R2DD | on Register (W)                      | ADDRESS : 0C5 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Port Direction<br>0: Input<br>1: Output                |
| R2 Pull-uj<br>R2PC | o Selection Register (W)             | ADDRESS :0FA <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Pull-up select<br>1: Without pull-up<br>0: With pull-up |
| R2 Open<br>R2ODC   | drain Assign Register (W             | ADDRESS :0DF <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub>                                                            |

#### (1) R2 I/O Data Direction Register (R2DD)

R2 I/O Data Direction Register (R2DD) is 8-bit register, and can

assign input state or output state to each bit. If R2DD is ``1``, port R2 is in the output state, and if ``0``, it is in the input state. R2DD is write-only register. Since R2DD is initialized as ``00 h`` in reset state, the whole port R2 becomes input state.

### (2) R2 Data Register (R2)

R2 data register (R2) is 8-bit register to store data of port R2. When set as the output state by R2DD, and data is written in R2, data is outputted into R2 pin. When set as the input state, input state of pin is read. The initial value of R2 is unknown in reset state.

#### (3) R2 Open drain Assign Register (R2ODC)

R2 Open Drain Assign Register (R2ODC) is 8bit register, and can assign R2 port as open drain output port each bit, if corresponding port is selected as output. If R2ODC is selected as ``1``, port R2 is open drain output, and if selected as ``0``, it is push-pull output. R2ODC is write-only register and initialized as ``00 h`` in reset state.

#### (4) R2 Pull-up Resistor Control Register (R2PC)

R2 pull-up resistor control register (R2PC) is 8-bit register and can control pull-up on or off each bit, if corresponding port is selected as input. If R2PC is selected as ``1``, pull-up ia disabled and if selected as ``0``, it is enabled. R2PC is write-only register and initialized as ``00 h`` in reset state. The pull-up is automatically disabled, if corresponding port is selected as output.

#### **R3 Port**

R3 is an 8-bit CMOS bidirectional I/O port (address  $0E5_H$ ). Each I/O pin can independently used as an input or an output through the R3DD register (address  $0E6_H$ ).

R3 has internal pull-ups that is independently connected or disconnected by R3PC (address  $0FB_H$ ). The control registers for R3 are shown as below.

| R3 Data R<br>R3    | Register (R/W)<br>R37 R36 R35 R34 R3 | ADDRESS : 0E5 <sub>H</sub><br>RESET VALUE : Undefined<br>33 R32 R31 R30                                          |
|--------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------|
| R3 Directi<br>R3DD | on Register (W)                      | ADDRESS : 0E6 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Port Direction<br>0: Input<br>1: Output           |
| R3 Pull-u<br>R3PC  | p Selection Register (W)             | ADDRESS :0FB <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>                                                   |
| R3 Open<br>R3ODC   | drain Assign Register (W             | ADDRESS :0E0 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Open drain select<br>0: Push-pull<br>1: Open drain |

#### (1) R3 I/O Data Direction Register (R3DD)

R3 I/O Data Direction Register (R3DD) is 8-bit register, and can assign input state or output state to each bit. If R3DD is ``1``, port R3 is in the output state, and if ``0``, it is in the input state. R3DD is write-only register. Since R3DD is initialized as ``00 h`` in reset state, the whole port R3 becomes input state.

#### (2) R3 Data Register (R3)

R3 data register (R3) is 8-bit register to store data of port R3. When set as the output state by R3DD, and data is written in R3, data is outputted into R3 pin. When set as the input state, input state of pin is read. The initial value of R3 is unknown in reset state.

#### (3) R3 Open drain Assign Register (R3ODC)

R3 Open Drain Assign Register (R3ODC) is 8bit register, and can assign R3 port as open drain output port each bit, if corresponding port is selected as output. If R3ODC is selected as ``1``, port R3 is open drain output, and if selected as ``0``, it is push-pull output. R3ODC is write-only register and initialized as ``00 h`` in reset state.

#### (4) R3 Pull-up Resistor Control Register (R3PC)

R3 pull-up resistor control register (R3PC) is 8-bit register and can control pull-up on or off each bit, if corresponding port is selected as input. If R3PC is selected as ``1``, pull-up ia disabled and if selected as ``0``, it is enabled. R3PC is write-only register and initialized as ``00 h`` in reset state. The pull-up is automatically disabled, if corresponding port is selected as output.

#### **R4 Port**

R4 is an 1-bit CMOS bidirectional I/O port (address  $0E7_{\rm H}$ ). Each I/O pin can independently used as an input or an output through the R4DD register (address  $0E8_{\rm H}$ ).

R3 has internal pull-ups that is independently connected or disconnected by R4PC (address  $0FC_H$ ). The control registers for R4 are shown as below.

| R4 Data F<br>R4    | Register (R/W)           | ADDRESS : 0E7 <sub>H</sub><br>RESET VALUE : Undefined<br>I3 R42 R41 R40                                               |
|--------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------|
| R4 Directi<br>R4DD | ion Register (W)         | ADDRESS : 0E8 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Port Direction<br>0: Input<br>1: Output                |
| R4 Pull-u<br>R4PC  | p Selection Register (W) | ADDRESS :0FC <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Pull-up select<br>1: Without pull-up<br>0: With pull-up |
| R4 Open<br>R4ODC   | drain Assign Register (W | ADDRESS :0E1 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub><br>Open drain select<br>0: Push-pull<br>1: Open drain      |

#### (1) R4 I/O Data Direction Register (R4DD)

R4 I/O Data Direction Register (R4DD) is 1-bit register, and can assign input state or output state to each bit. If R4DD is ``1``, port R4 is in the output state, and if ``0``, it is in the input state. R4DD is write-only register. Since R4DD is initialized as ``00 h`` in reset state, the whole port R4 becomes input state.

#### (2) R4 Data Register (R4)

R4 data register (R4) is 1-bit register to store data of port R4. When set as the output state by R4DD, and data is written in R4, data is outputted into R4 pin. When set as the input state, input state of pin is read. The initial value of R4 is unknown in reset state.

#### (3) R4 Open drain Assign Register (R4ODC)

R4 Open Drain Assign Register (R4ODC) is 1-bit register, and can assign R4 port as open drain output port each bit, if corresponding port is selected as output. If R4ODC is selected as ``1``, port R4 is open drain output, and if selected as ``0``, it is pushpull output. R4ODC is write-only register and initialized as ``00 h`` in reset state.

#### (4) R4 Pull-up Resistor Control Register (R4PC)

R4 pull-up resistor control register (R4PC) is 1-bit register and can control pull-up on or off each bit, if corresponding port is selected as input. If R4PC is selected as ``1``, pull-up ia disabled and if selected as ``0``, it is enabled. R4PC is write-only register and initialized as ``00 h`` in reset state. The pull-up is automatically disabled, if corresponding port is selected as output.

## **11. CLOCK GENERATOR**

Clock generating circuit consists of Clock Pulse Generator (C.P.G), Prescaler, Basic Interval Timer (B.I.T) and Watch Dog

Timer. The clock applied to the Xin pin divided by two is used as the internal system clock.



Figure 11-1 Block Diagram of Clock Generator

Prescaler consists of 12-bit binary counter. The clock supplied from oscillation circuit is input to prescaler (fex). The divided

output from each bit of prescaler is provided to peripheral hard-ware.



Figure 11-2 Block diagram of Prescaler

## MagnaChip

| fox (MHz) | 4 MHz     |         | 2 MHz     |         |
|-----------|-----------|---------|-----------|---------|
| fex (MHz) | frequency | period  | frequency | period  |
| ps 0      | 4 MHz     | 250 ns  | 2 MHz     | 500 ns  |
| ps 1      | 2 MHz     | 500 ns  | 1 MHz     | 1 us    |
| ps 2      | 1 MHz     | 1 us    | 500 KHz   | 2 us    |
| ps 3      | 500 KHz   | 2 us    | 250 KHz   | 4 us    |
| ps 4      | 250 KHz   | 4 us    | 125 KHz   | 8 us    |
| ps 5      | 125 KHz   | 8 us    | 62.5 KHz  | 16 us   |
| ps 6      | 62.5 KHz  | 16 us   | 31.25 KHz | 32 us   |
| ps 7      | 31.25 KHz | 32 us   | 15.63 KHz | 64 us   |
| ps 8      | 15.63 KHz | 64 us   | 7.183 KHz | 128 us  |
| ps 9      | 7.183 KHz | 128 us  | 3.906 KHz | 256 us  |
| ps 10     | 3.906 KHz | 256 us  | 1.953 KHz | 512 us  |
| ps 11     | 1.953 KHz | 512 us  | 0.976 KHz | 1024 us |
| ps 12     | 0.976 KHz | 1024 us | 0.488 KHz | 2048 us |
|           |           |         |           |         |

 Table 11-1 ps output period

 lock to peripheral hardware can be stopped by bit4 (ENPCK) of

 CKCTLR Register.

 ENPCK is set to ``1`` in reset state.

## 12. Timer

#### 12.1 Basic Interval Timer

The GMS81C5016/24/32 has one 8-bit Basic Interval Timer that is free-run and can not stop. Block diagram is shown in Figure 12-1.

The Basic Interval Timer generates the time base for key scanning, watchdog timer counting, and etc. It also provides a Basic interval timer interrupt (IFBIT). As the count overflow from  $FF_H$  to  $00_H$ , this overflow causes the interrupt to be generated.

-8bit binary counter

-Use the bit output of prescaler as input to secure the oscillation stabilization time after power-on

-Secures the oscillation stabilization time in standby mode (stop mode) release

-Contents of B.I.T can be read

-Provides the clock for watch dog timer.



Figure 12-1 Block Diagram of Basic Interval Timer

#### (1) Control of B.I.T

The Basic Interval Timer is controlled by the clock control register (CKCTLR) shown in Figure 12-2. If bit3(BTCL) of CKCTLR is set to ``1``, B.I.T is cleared, and then, after one machine cycle, BTCL becomes ``0``, and B.I.T starts counting. BTCL is set to ``0`` in reset state.



Figure 12-2 BTCL mode of B.I.T

### (2) Input clock selection of B.I.T

The input clock of B.I.T can be selected from the prescaler within a range of 2us to 256us by clock input selection bits (BTS2~BTS0). (at fex = 4MHz). In reset state, or power on reset, BTS2=``1``, BTS1=``1``, BTS0=``1`` to secure the longest oscillation stabilization time. B.I.T can generate the wide range of basic interval time interrupt request (IFBIT) by selecting prescaler output. Interrupt interval can be selected to kinds of interval time as shown in

Figure 12-3.



#### Figure 12-3 Basic Interval Timer Interrupt Time

#### (3) Reading Basic Interval Timer

By reading of the Basic Interval Timer Register (BITR), we can read counter value of B.I.T. Because B.I.T can be cleared or read, the spending time up to maximum 65.5ms can be available. B.I.T is read-only register. If B.I.T register is written, then CKCTLR register with same address is written.



#### 12.2 Timer0, Timer1, Timer2

#### (1) Timer Operation Mode

Timer consists of 16bit binary counter Timer0 (T0), 8bit binary Timer1 (T1), Timer2 (T2), Timer Data Register, Timer Mode Register (TM01, TM0, TM1, TM2) and control circuit. Timer Data Register Consists of Timer0 High-MSB Data Register (T0HMD), Timer0 High-LSB Data Register (T0HLD), Timer0 Low-MSB Data Register (T0LMD), Timer0 Low-LSB Data Register (T0LLD), Timer1 High Data Register (T1HD), Timer1 Low Data Register (T1LD), Timer2 Data Register (T2DR). Any of the PS0 ~ PS5, PS11 and external event input EC can be selected as clock source for T0. Any of the PS0 ~ PS3, PS7 ~ PS10 can be selected as clock T1. Any of the PS5 ~ PS12 can be selected as clock source for T2.

\* Relevant Port Mode Register (PMR1 : 00C9 h) value should be assigned for event counter,

| Timer0 | - 16-bit Interval Timer<br>- 16-bit Event Counter<br>- 16-bit Input Capture<br>- 16-bit rectangular-wave output | <ul> <li>Single/Modulo-N Mode</li> <li>Timer Output Initial Value Setting</li> <li>Timer0~Timer1 combination Logic Output</li> <li>One Interrupt Generating Every 2nd</li> </ul> |
|--------|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer1 | - 8-bit Interval Timer<br>- 8-bit rectangular-wave output                                                       | Counter Overflow                                                                                                                                                                 |
| Timer2 | - 8-bit Interval Timer<br>- 8-bit rectangular-wave output<br>- Modulo-N Mode                                    |                                                                                                                                                                                  |



Figure 12-4 Timer / Counter Block diagram

# (2) Function of Timer & Counter

|                 |               |                 |            |                 | tex = 4MHz |  |
|-----------------|---------------|-----------------|------------|-----------------|------------|--|
| 16bit Tim       | er (T0)       | 8bit Time       | r (T1)     | 8bit Timer (T2) |            |  |
| Resolution (CK) | Max. Count    | Resolution (CK) | Max. Count | Resolution (CK) | Max. Count |  |
| PS0 ( 0.25 us)  | 16,384 us     | PS0 ( 0.25 us)  | 64 us      | PS5 ( 8 us)     | 2.048 us   |  |
| PS1 (0.5 us)    | 32,768 us     | PS1 ( 0.5 us)   | 128 us     | PS6 ( 16 us)    | 4,096 us   |  |
| PS2 ( 1 us)     | 65,536 us     | PS2 ( 1 us)     | 256 us     | PS7 ( 32 us)    | 8,192 us   |  |
| PS3 ( 2 us)     | 131,072 us    | PS3 ( 2 us)     | 512us      | PS8 ( 64 us)    | 16,384 us  |  |
| PS4 ( 4 us)     | 262,144 us    | PS7 ( 32 us)    | 8,192 us   | PS9 ( 128 us)   | 32,768 us  |  |
| PS5 ( 8 us)     | 524,288 us    | PS8 ( 64 us)    | 16,384 us  | PS10(256 us)    | 65,536 us  |  |
| PS11(512 us)    | 33,554,432 us | PS9 ( 128 us)   | 32,768 us  | PS11(512 us)    | 131,072 us |  |
| EC              | -             | PS10(256 us)    | 65,536 us  | PS12 (1,024 us) | 262,144 us |  |

fex = 4MHz



Figure 12-5 Block Diagram of Timer0



Figure 12-6 Block Diagram of Timer1



#### Figure 12-7 Block Diagram of Timer2



Figure 12-8 Timer0 / Timer1 Mode Register

# MagnaChip

|     | 7    |         | Tir   | ner0 Mod  | le Regist    | er          |             | 0       |                |
|-----|------|---------|-------|-----------|--------------|-------------|-------------|---------|----------------|
| TM0 | CAP0 | TOST    | T0CN  | TOMOD     | T0IFS        | T0SL2       | T0SL1       | T0SL0   | R / W <00D0 h> |
|     |      |         |       |           |              |             |             |         | _              |
|     |      |         |       |           |              |             |             |         |                |
|     |      | 🕞       | T0SL2 | T0SL1     | TOSLO        | ) Inpu      | it clock se | lection | Notes          |
|     |      |         | 0     | 0         | 0            | PS0         | (250ns)     |         |                |
|     |      | _       | 0     | 0         | 1            | PS1         | (500ns)     |         | *              |
|     |      | _       | 0     | 1         | 0            | PS2         | ( 1us)      |         |                |
|     |      | _       | 0     | 1         | 1            | PS3         | ( 2us)      |         |                |
|     |      | _       | 1     | 0         | 0            | PS4         | ( 4us)      |         |                |
|     |      | _       | 1     | 0         | 1            | PS5         | ( 8us)      |         |                |
|     |      | _       | 1     | 1         | 0            |             | 1 (512us)   |         | Event          |
|     |      | .       | 1     | 1         | 1            | EC          |             |         | Counter        |
|     |      | '       | T0IFS |           | Timer0 In    | iterrupt Se | election    |         |                |
|     |      | •       | 0     | Interrupt | every cou    | nter overf  | low         |         |                |
|     |      | -       | 1     | Interrupt | every 2nd    | counter     | overflow    |         |                |
|     |      |         | TOMOD | Tim       | er0 Single   | e/Modulo-   | N Selectic  | on      |                |
|     |      |         | 0     | Modulo-N  | N            |             |             |         |                |
|     |      | -       | 1     | Single    |              |             |             |         |                |
|     |      | <b></b> | TOCN  | Timer0 (  | Counter Co   | ontinuatio  | n/Pause (   | Control |                |
|     |      | -       | 0     | Count pa  | ause         |             |             |         |                |
|     |      | -       | 1     | Count co  | ontination   |             |             |         |                |
|     |      |         | TOST  |           | Timer0 S     | tart/Stop   | Control     |         |                |
|     |      | -       | 0     | Timer0 S  | stop         |             |             |         |                |
|     |      | -       | 1     | Timer Sta | art after cl | ear         |             |         |                |
|     |      |         | CAP0  |           | Timer0 In    | iterrupt Se | election    |         |                |
|     |      | _       | 0     | Timer/Co  | ounter       |             |             |         |                |
|     |      | •       | 1     | Input cap | oture *      |             |             |         |                |

\* PS1 : not supporting input capture.

### Figure 12-9 Timer0 Mode Register

|     | 7    |       | Tir   | ner1 Mod  | le Regist  | ter         |              | 0       |                |
|-----|------|-------|-------|-----------|------------|-------------|--------------|---------|----------------|
| TM1 | T1ST | T1CN  | T1MOD | T1IFS     | -          | T1SL2       | T1SL1        | T1SL0   | R / W <00D1 h> |
|     |      |       |       |           |            |             |              |         |                |
|     |      |       |       |           |            |             |              |         |                |
|     |      |       | T1SL2 | T1SL1     | T1SL0      | ) Inpu      | it clock sel | ection  |                |
|     |      | -     | 0     | 0         | 0          | PS0         | (250ns)      |         |                |
|     |      | -     | 0     | 0         | 1          | PS1         | (500ns)      |         |                |
|     |      | -     | 0     | 1         | 0          | PS2         | ( 1us)       |         |                |
|     |      | _     | 0     | 1         | 1          | PS3         | ( 2us)       |         |                |
|     |      | -     | 1     | 0         | 0          | PS7         | ( 32us)      |         |                |
|     |      | -     | 1     | 0         | 1          | PS8         | ( 64us)      |         |                |
|     |      | _     | 1     | 1         | 0          | PS9         | (128us)      |         |                |
|     |      |       | 1     | 1         | 1          | PS1         | 0 (256us)    |         |                |
|     |      | L_• ] | T1IFS |           | Timer1 Ir  | nterrupt Se | election     |         |                |
|     |      | -     | 0     | Interrupt | every cou  | inter over  | low          |         |                |
|     |      |       | 1     | Interrupt | every 2nd  | l counter o | overflow     |         |                |
|     |      |       | T1MOD | Tim       | er1 Single | e/Modulo-   | N Selectio   | n       |                |
|     |      |       | 0     | Modulo-N  | ١          |             |              |         |                |
|     |      |       | 1     | Single    |            |             |              |         |                |
|     |      |       | T1CN  | Timer1 (  | Counter C  | ontinuatio  | n/Pause C    | Control |                |
|     |      |       | 0     | Count pa  | iuse       |             |              |         |                |
|     |      | -     | 1     | Count co  | ntination  |             |              |         |                |
|     |      |       | T1ST  |           | Timer1 S   | tart/Stop   | Control      |         |                |
|     |      | -     | 0     | Timer1 S  | itop       |             |              |         |                |
|     |      | -     | 1     | Timer1 S  | tart after | clear       |              |         |                |

Figure 12-10 Timer1 Mode Register

# MagnaChip

|     | 7 |          | Tir   | mer2 Moc | le Regis    | ter        |             | 0       | _              |
|-----|---|----------|-------|----------|-------------|------------|-------------|---------|----------------|
| TM2 | - | -        | -     | T2ST     | T2CN        | T2SL2      | T2SL1       | T2SL0   | R / W <00D2 h> |
|     |   |          |       |          |             |            |             |         | -              |
|     |   |          |       |          |             |            |             |         |                |
|     |   | └-▶]     | T2SL2 | T2SL1    | T2SL        | ) Inpu     | t clock sel | ection  |                |
|     |   | -        | 0     | 0        | 0           | PS5        | ( 8us)      | )       |                |
|     |   | -        | 0     | 0        | 1           | PS6        | ( 16us)     | )       |                |
|     |   |          | 0     | 1        | 0           | PS7        | ( 32us)     | )       |                |
|     |   |          | 0     | 1        | 1           | PS8        | ( 64us)     | )       |                |
|     |   |          | 1     | 0        | 0           | PS9        | (128us)     | )       |                |
|     |   |          | 1     | 0        | 1           | PS1        | 0 (256us)   | )       |                |
|     |   |          | 1     | 1        | 0           | PS1        | 1 (512us)   | )       |                |
|     |   |          | 1     | 1        | 1           | PS1        | 2 (1024us)  | )       |                |
|     |   |          | T2CN  | Timer2   | Counter C   | ontinuatio | n/Pause C   | Control |                |
|     |   | -        | 0     | Count pa | ause        |            |             |         |                |
|     |   | -        | 1     | Count co | ontination  |            |             |         |                |
|     | L | <b>`</b> | T2ST  |          | Timer2 S    | itart/Stop | Control     |         |                |
|     |   | -        | 0     | Timer2 S | Stop        |            |             |         |                |
|     |   | -        | 1     | Timer2 S | Start after | clear      |             |         |                |







Register

#### (3) Timer0, Timer1

TIMER0 and TIMER1 have an up-counter. When value of the up-counter reaches the content of Timer Data Register (TDR),

the up-counter is cleared to ``00 h``, and interrupt (IFT0, IFT1) is occured at the next clock.



Figure 12-13 Operatiion of Timer0

For Timer0, the internal clock (PS) and the external clock (EC) can be selected as counter clock. But Timer1 and Timer2 use only internal clock. As internal clock. Timer0 can be used as internaltimer which period is determined by Timer Data Register (TDR). Chosen as external clock, Timer0 executes as event-counter. The counter execution of Timer0 and Timer1 is controlled by T0CN, T0ST, CAP0, T1CN, T1ST, of Timer Mode Register TM0 and TM1. T0CN, T1CN are used to stop and start Timer0 and Timer1 without clearing the counter. TOST, T1ST is used to clear the counter. For clearing and starting the counter, T0ST or T1ST should be temporarily set to ``0`` and then set to ``1``. T0CN, T1CN, T0ST and T1ST should be set ``1``, when Timer counting-up. Controlling of CAP0 enables Timer0 as input capture. By programming of CAP0 to ``1``, the period of signal from INT2 can be measured and then, event counter value for INT2 can be read. During counting-up, value of counter can be read.

Timer execution is stopped by the reset signal (RESET = ``L``)

**Note:** In the process of reading 16-bit Timer Data, first read the upper 8-bit data. Then read the lower 8-bit data, and read the upper 8-bit data again. If the earlier read upper 8-bit data are matched with the later read upper 8-bit data, read 16-bit data are correct. If not, caution should be taken in the selection of upper 8-bit data.

(Example)

1) Upper 8-bit Read 0A 0A
 2) Lower 8-bit Read FF 01

3) Upper 8-bit Read 0B 0B

0AFF 0B01



Figure 12-14 Start/Stop operation of Timer0



Figure 12-15 Input capture operation of Timer0

#### \* Single/Modulo-N Mode

Timer0 (Timer1) can select initial (T0INIT, T1INIT of TM01) output level of Timer Output port. If initial level is ``L``, Low-Data Register value of Timer Data Register is transferred to comparator and T0OUT (T1OUT) is to be ``Low``, if initial level is High? High -Data Register is transferred and to be ``High``. Single Mode can be set by Mode Select bit (T0MOD, T1MOD) of Timer Mode Register (TM0, TM1) to ``1`` When used as Single Mode, Timer counts up and compares with value of Data Register. If the result is same, Time Out interrupt occurs and level of Timer Output port toggle, then counter stops as reset state. When used as Modulo-N Mode, T0MOD (T1MOD) should be set ``0``. Counter counts up until the value of Data Register and occurs Time-out interrupt. The level of Timer Output port toggle and repeats process of

counting the value which is selected in Data Register. During

Modulo-N Mode, If interrupt select bit (T0IFS, T1IFS) of Mode Register is ``0``, Interrupt occurs on every Time-out. If it is ``1``, Interrupt occurs every second time-out.

**Note:** (\*note. Timer Output is toggled whenever time out happen)



Figure 12-16 Operation Diagram for Single/Modulo-N Mode

### (4) Timer 2

Timer2 operates as a up-counter. The content of T2DR are compared with the contents of up-counter. If a match is found. Timer2 interrupt (IFT2) is generated and the up-counter is cleared to ``00 h``. Therefore, Timer2 executes as a interval timer. Interrupt period is determined by the count source clock for the Timer2 and content of T2DR. When T2ST is set to ``1``, count value of Timer 2 is cleared and starts counting-up. For clearing and starting the Timer2. T2ST have to set to ``1`` after set to ``0``. In order to write a value directly into the T2DR, T2ST should be set to ``0``. Count value of Timer2 can be read at any time.



Figure 12-17 Operation of Timer2



Figure 12-18 Start/Stop of Timer2

# **13. INTERRUPTS**

The GMS81C5016/24/32 interrupt circuits consist of Interrupt Mode Register (MOD), Interrupt enable register (IENH, IENL), Interrupt request flags of IRQH, IRQL, Priority circuit and Master enable flag ("I" flag of PSW). 8 interrupt sources are provided. The configuration of interrupt circuit is shown in Figure 13-1.

The GMS81C5016/24/32 contains 8 interrupt sources; 3 externals and 5 internals. Nested interrupt services with priority control is also possible. Software interrupt is non-maskable interrupt, the others are all maskable interrupts.

- 8 interrupt source (2Ext, 3Timer, BIT, WDT and Key Scan)

- 8 interrupt vector
- Nested interrupt control is possible
- Programmable interrupt mode
- Hardware accept mode
- Software selection accept mode
- Read and write of interrupt request flag are possible.
- In interrupt accept, request flag is automatically cleared.



Figure 13-1 Block Diagram of Interrupt

#### 13.1 Interrupt priority and sources.

Each interrupt vector is independent and has its own priority. Software interrupt (BRK) is also available. Interrupt source classification is shown in Table 13-1.

|              | Mask         | Priority | Interrupt Source            | INT Vector High | INT Vector Low |
|--------------|--------------|----------|-----------------------------|-----------------|----------------|
|              | non-maskable | -        | RST (RESET pin)             | FFFF            | FFFE           |
|              |              | 0        | KSCNR (Key Scan)            | FFFB            | FFFA           |
|              |              | 1        | INT1R (External Interrupt1) | FFF9            | FFF8           |
|              |              | 2        | INT2R (External Interrupt2) | FFF7            | FFF6           |
| Hardwar<br>e | maskable     | 3        | T0R (Timer0)                | FFF3            | FFF2           |
| Interrupt    |              | 4        | T1R (Timer1)                | FFF1            | FFF0           |
|              |              | 5        | T2R (Timer2)                | FFEF            | FFEE           |
|              |              | 6        | WDTR (Watctdog Timer)       | FFE9            | FFE8           |
|              |              | 7        | BITR (Basic Interval Timer) | FFE7            | FFE6           |
|              | -            | -        | BRK instruction             | FFDF            | FFDE           |

| Table 13- | Interrupt | Priority | & Source |
|-----------|-----------|----------|----------|
|-----------|-----------|----------|----------|

### **13.2 INTERRUPT CONTROL REGISTER**

I flag of PSW is a interrupt mask enable flag. When I flag = ``0``, all interrupts become disable. When I flag = ``1``, interrupts can be selectively enabled and disabled by contents of corresponding Interrupt Enable Register. When interrupt is occured, interrupt request flag is set, and Interrupt request is detected at the edge of interrupt signal. The accepted interrupt request flag is automati-

cally cleared during interrupt cycle process. The interrupt request flag maintains ``1`` until the interrupt is accepted or is cleared in program. In reset state, interrupt request flag register (IRQH, IRQL) is cleared to ``0``. It is possible to read the state of interrupt register and to mainpulate the contents of register and to generate interrupt. (Refer to software interrupt).

| IENI |       |       |       | I. | I.  |     | I.  |   | R/W <00CCh>   |
|------|-------|-------|-------|----|-----|-----|-----|---|---------------|
| IENL | -     | WDTR  | BITE  | -  | -   | -   | -   | - | R/W <00CEh>   |
| IENH | KSCNE | INT1E | INT2E | -  | T0E | T1E | T2E | - | R/W <00CDh>   |
| IRQL | -     | WDTR  | BITE  | -  | -   | -   | -   | - | R/W <00CDh>   |
| IRQH | KSCNE | INT1R | INT2R | -  | T0R | T1R | T2R | - | к/ w >00СгII> |

IENL : INTERRUPT ENABLE REGISTER LOW IENH : INTERRUPT ENABLE REGISTER HIGH IRQL : INTERRUPT REQUEST REGISTER LOW IRQH : INTERRUPT REQUEST REGISTER HIGH

### 13.3 INTERRUPT ACCEPT MODE

The interrupt priority order is determined by bit (IM1, IM0) of

IMOD register.



# (1) Selection of Interrupt by IP3-IP0

The condition allow for accepting interrupt is set state of the interrupt mask enable flag and the interrupt enable bit must be ``1``. In Reset state, these IP3 - IP0 registers become all ``0``.

| IP3 | IP2 | IP1 | IP0 | Selection Interrupt          |
|-----|-----|-----|-----|------------------------------|
| 0   | 0   | 0   | 1   | KSCNR (Key Scan)             |
| 0   | 0   | 1   | 0   | INT1R (External interrupt 1) |
| 0   | 0   | 1   | 1   | INT2R (External interrupt 2) |
| 0   | 1   | 0   | 0   | Reserved                     |
| 0   | 1   | 0   | 1   | T0R (Timer 0)                |
| 0   | 1   | 1   | 0   | T1R (Timer 1)                |
| 0   | 1   | 1   | 1   | T2R (Timer 2)                |
| 1   | 0   | 0   | 0   | Reserved                     |
| 1   | 0   | 0   | 1   | Reserved                     |
| 1   | 0   | 1   | 0   | WDTR (Watch Dog Timer)       |
| 1   | 0   | 1   | 1   | BITR (Basic Interval Timer)  |
| 1   | 1   | 0   | 0   | Reserved                     |

Table 13-1 Interrupt Selection by IP3 - IP0

### (2) Interrupt Timing





\*Interrupt Request sampling time

-Maximum 12 machine cycle (When execute DIV

instruction)

-Minimum 0 machine cycle

\*Interrupt preprocess step is 8 machine cycle

(3) The valid timing after executing Interrupt control instructions

I flag is valid just after executing of EI/DI on the contrary. Interrupt Enable register is valid one instruction after controlling in-

### **13.4 INTERRUPT PROCESSING SEQUENCE**

When an interrupt is accepted, the on-going process is stopped and the interrupt service routine is executed. After the interrupt service routine is completed it is necessary to restore everything to the state before the interrupt occured. As soon as an interrupt is accepted, the content of the program counter and PSW are savedin the stack area. At the same time, the content of the vector address corresponding to the accepted interrupt, which is in the interrupt vector table, enters into the program counter and interrupt service is executed. In order to execute the interrupt service routine, it is necessary to write the jump addresses in the vector table (FFE0 h  $\sim$  FFFF h) corresponding to each interrupt \*Interrupt overhead

terrupt Enable Register.

-Maximum 1 + 12 + 8 = 21 machine cycle -Minimum 1 + 0 + 8 = 9 machine cycle

\* Interrupt Processing Step

1) Store upper byte of Program Counter, SP <= SP

2) Store lower byte of Program Counter, SP  $\leq$  SP - 1

3) Store Program Status Word, SP <= SP - 2

4) After resetting of I-flag, clear accepted Interrupt Request Flag. (Set B-flag for BRK Instruction)

5) Call Interrupt service routine





#### 13.5 SOFTWARE INTERRUPT (Interrupt by Break (BRK) Instruction)

Software interrupt is available just by writing ``Break(BRK)`` instruction. The values of PC and PSW is stacked by BRK instruction and then B flag of PSW is set and I flag is reset.



Interrupt vector of BRK instruction is shared by vector of Table Call (TCALL0). When both instruction of BRK and TCALL0 are used, as shown in Figure 13-4each processing routine is

judged by contents of B flag. There is no instruction to reset directly B flag.



Figure 13-4 Execution of BRK or TCALL0

#### **13.6 MULTIPLE INTERRUPT**

If there is an interrupt, Interrupt Mask Enable Flag is automatically cleared before entering the Interrupt Service Routine. After then, no interrupt is accepted. If EI instruction is executed, interrupt mask enable bit becomes ``1``, and each enable bit can ac-

cept interrupt request. When two or more interrupts are generated simultaneously, the highest priority interrupt set by Interrupt Mode Register is accepted.

#### 13.7 Key Scan Input Processing

#### (1) Standby Mode Release Register (SMRR)

Key Scan Interrupt is generated by detecting low or high Input from each Input pin (R0, R1) is one of the sources which release standby (SLEEP, STOP) mode. Key Scan ports are all 16bit which are controlled by Standby Mode Release Register (SMRR0, SMRR1). Key Input is considered as Interrupt, therefore, KSCNE bit of IEHN should be set for correct interrupt executing, SLEEP mode and STOP mode, the rest of executing is the same as that of external Interrupt. Each SMRR Register bit is allowed for each port (for Bit=``0``, no Key Input, for Bit=``1``,

Key Input available). At reset, SMRR becomes ``00 h``. So, there is no Key Input source.



Figure 13-5 Key Scan Block



| SMRI | SMRR0 |       | R1 | Key Input Selection |
|------|-------|-------|----|---------------------|
| KR07 | 0     | KR17  | 0  | no select           |
|      | 1     |       | 1  | select              |
| KR06 | 0     | KR16  | 0  | no select           |
| KK00 | 1     | KK 10 | 1  | select              |
| KR05 | 0     | KR15  | 0  | no select           |
| KRU0 | 1     | KK ID | 1  | select              |
| KR04 | 0     | KR14  | 0  | no select           |
| KK04 | 1     |       | 1  | select              |
| KR03 | 0     | KR13  | 0  | no select           |
| KRU3 | 1     | KK IS | 1  | select              |
| KR02 | 0     | KR12  | 0  | no select           |
| KRU2 | 1     | KR12  | 1  | select              |
| KR01 | 0     | KR11  | 0  | no select           |
|      | 1     |       | 1  | select              |
| KR00 | 0     | KR10  | 0  | no select           |
|      | 1     |       | 1  | select              |

### (2) Standby Release Level Control Register (SRLC)

Standby release level control register (SRLC) can select the key scan input level ``L`` or ``H`` for standby release by each bit pin

(R0, R1). Standby release level control register (SRLC) is write-only register and initialized as ``00 h`` in reset state.



# MagnaChip

| SRLC  | SRLC0 |        | 21 | Key Input Level |  |
|-------|-------|--------|----|-----------------|--|
| KLR07 | 0     | KLR17  | 0  | Low             |  |
|       | 1     |        | 1  | High            |  |
| KLR06 | 0     | KLR16  | 0  | Low             |  |
| KLKU0 | 1     | KLK 10 | 1  | High            |  |
| KLR05 | 0     | KLR15  | 0  | Low             |  |
| KLK05 | 1     | KLK15  | 1  | High            |  |
| KLR04 | 0     | KLR14  | 0  | Low             |  |
|       | 1     | NLK 14 | 1  | High            |  |
| KLR03 | 0     | KLR13  | 0  | Low             |  |
| NLR03 | 1     | KLK13  | 1  | High            |  |
| KLR02 | 0     | KLR12  | 0  | Low             |  |
| NLRU2 | 1     | NLR 12 | 1  | High            |  |
| KLR01 | 0     | KLR11  | 0  | Low             |  |
|       | 1     |        | 1  | High            |  |
| KLR00 | 0     | KLR10  | 0  | Low             |  |
|       | 1     |        | 1  | High            |  |

# **14. WATCH DOG TIMER**

Watch Dog Timer (WDT) consists of 6-bit binary counter, 6-bit



Figure 14-1 Block diagram of Watch Dog Timer

# 14.1 Control of WDT

Watch Dog Timer can be used 6-bit general Timer or specific Watch dog timer by setting

bit5 (WDTON) of Clock Control Register (CKCTLR).



By assigning bit6(WDTCL) of WDTR, 6-bit counter can be cleared.

comparator, and Watch Dog Timer Register (WDTR).



# 14.2 WDT Interrupt Interval

WDT Interrupt (IFWDT) interval is determined by the interrupt IFBIT interval of Basic Interval Timer and the value of WDT Register.

-Interval of IFWDT = (IFBIT interval) \* (WDTR value)

-Interval of IFWDT : 512 us \* 1 = 512 us (MIN>)

-65,536us \* 63 = 4,128,768 us (MAX>)

As IFBIT (Basic Interval Timer Interrupt Request) is used for input clock of WDT, Input clock cycle is possible from 512 us to 65,536 us by BTS. (at fex = 4MHz) \*At Hardware reset time ,WDT starts automatically. Therefore, the user must select the CKCTLR, WDTR before WDT over-flow.

-Reset WDTR value = 0F h,15

-interval of WDT = 65,536 \* 15 = 983040 us

(about 1second)



**Note:** When WDTR Register value is 63 (3F h) (Caution) : Do not use ``0`` for WDTR Register value.

Device come into the reset state by WDT

# **15. STANDBY FUNCTION**

To save power consumption, there is STOP modes. In this modes,

#### 15.1 Sleep Mode

SLEEP mode can be entered by setting the bit of SLEEP mode register (SLPM). In the mode, CPU clock stops but oscillator keeps running. B.I.T and a part of peripheral hardware execute, but prescalerís output which provide clock to peripherals can be stopped by program. (Except, PS10 canít stopped.) In SLEEP mode, more consuming power can be saved by not using other peripheral hardware except for B.I.T. By setting ENPCK (peripheral clock control bit) of CKCTLR (clock control register) to ``0``, peripheral hardware halted, and SLEEP mode is entered. To

the execution of program stops.

release SLEEP mode by BITR (basic interval timer interrupt), bit10 of prescaler should be selected as B.I.T input clock before entering SLEEP mode. ``NOP`` instruction should be follows setting of SLEEP mode for rising precharge time of data bus line.

(ex) setting of SLEEP mode : set the bit of SLEEP

; mode register (SLPM)

NOP

: NOP instruction



#### **15.2 STOP MODE**

STOP mode can be entered by STOP instruction during program. In STOP mode, oscillator is stopped to make all clocks stop, which leads to less power consumption. All registers and RAM data are preserved. "NOP" instruction should be follows STOP instruction for rising precharge time of Data Bus line.

(ex) STOP : STOP instruction execution NOP : NOP instruction



Figure 15-1 Block Diagram of Standby Circuit



Figure 15-2 ENPCK and Basic Interval Timer Clock

# **15.3 STANDBY MODE RELEASE**

Release of STANDBY mode is executed by RESET input and Interrupt signal. Register value is defined when Reset. When there is a release signal of STOP mode (Interrupt, RESET input), the instruction execution starts after stabilization oscillation time is set by value of BTS2  $\sim$  BTS0 and set ENPCK to ``1``.

| Release Signal   | SLEEP | STOP |
|------------------|-------|------|
| RESET            | 0     | 0    |
| KSCN (key input) | 0     | 0    |
| INT1 , INT2      | 0     | 0    |
| B.I.T            | 0     | Х    |

#### Table 15-1 Standby Mode Register

| Release Factor                  | Release Method                                                                                                                                                                                                                                                                                                                                        |  |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| RESET                           | By RESET Pin = Low level, Standby mode is release and system is initialized                                                                                                                                                                                                                                                                           |  |
| KSCN<br>(key input)             | Standby mode is released by low input of selected pin by key scan Input (SMRR0, SMRR1) In case of interrupt mask enable flag = ``0``, program executes just after standby instruction, if flag = ``1``, enters each interrupt service routine.                                                                                                        |  |
| INT1<br>INT2                    | When external interrupt (INT1, INT2) enable flag is ``1``, standby mode is released at the rising edge of each terminal. When Standby mode is released at interrupt. Mask Enable flag = ``0``, program executes from the next instruction of standby instruction. When ``1``, enters each interrupt service routine.                                  |  |
| Basic Interval Timer<br>(IFBIT) | When B.I.T is executed only by bit10 of prescaler (PS10), SLEEP mode can be release. Interrupt release SLEEP mode, when BIT interrupt enable flag is ``1``. When standby mode is released at interrupt. Mask enable flag = ``0``, program executes from the next instruction of SLEEP instruction. When ``1``, enters each interrupt service routine. |  |

Table 15-2 Standby Mode Release



Figure 15-3 Release Timing of Standby Mode

# **15.4 RELEASE OPERATION OF STANDBY MODE**

After standby mode is released, the operation begins according to content of related interrupt register just before standby mode start (Figure 15-4)

### (1) Interrupt Enable Flag(I) of PSW = ``0``

Release by only interrupt which interrupt enable flag = ``1``, and starts to execute from next to standby instruction (SLEEP or STOP).

### (2) Interrupt Enable Flag(I) of PSW = ``1``

Released by only interrupt which each interrupt enable flag = ``1``, and jump to the relevant interrupt service routine.

**Note:** When STOP instruction is used, B.I.T should guarantee the stabilization oscillation time. Thus, just before entering STOP mode, clock of bit10 (PS10) of prescaler is selected or peripheral hardware clock control bit (ENPCK) to ``1``, Therefore the clock necessary for stabilization oscillation time should be input into B.I.T. otherwise, standby mode is released by reset signal. In case of interrupt request flag and interrupt enable flag are both ``1``, standby mode is not entered.



Figure 15-4 Standby Mode Release Flow

| Internal circuit      | SLEEP mode                              | STOP mode |  |
|-----------------------|-----------------------------------------|-----------|--|
| Oscillator            | Active                                  | Stop      |  |
| Internal CPU clock    | Stop                                    | Stop      |  |
| Register              | Retained                                | Retained  |  |
| RAM                   | Retained                                | Retained  |  |
| I/O port              | Retained                                | Retained  |  |
| Prescaler             | Active                                  | Retained  |  |
| Basic Interval Timer  | PS10 selected : Active<br>Others : Stop | Stop      |  |
| Watch Dog Timer       | Stop                                    | Stop      |  |
| Timer                 | Stop                                    | Stop      |  |
| Address Bus, Data Bus | Retained                                | Retained  |  |

Table 15-1 Operation State in Standby Mode

# **16. OSCILLATION CIRCUIT**

Oscillation circuit is designed to be used either with a ceramic resonator or crystal oscillator. Fig. 4.2-(a) shows circuit diagrams using a crystal (or ceramic) oscillator. As shown in the diagram, oscillation circuits can be constructed by connecting a oscillator between Xout and Xin. Clock from oscillation circuit makes CPU clock via clock pulse generator, and then enters prescaler to make peripheral hardware clock. Alternately, the oscillator may be driven from an external source as shown is Fig. 4.2.-(b). In the Standby (STOP) mode, oscillatiion stop, Xout state goes to ``Hligh``, Xin state goes to ``Low``, and built-in feed back resistor is disabled.



Figure 16-1 Oscillator configurations

\* Recommendable resonator

| Frequency | Resonator Maker | Part Name | Load Capacitor | Operating Voltage |
|-----------|-----------------|-----------|----------------|-------------------|
|           | CQ              | ZTA4.00MG | Cin=Cout=30pF  | 2.2 ~ 4.0V        |
| 4.0 MHz   | TDK             | FCR4.0MC5 | Cin=Cout=open  | 2.2 ~ 4.0V        |
|           | TDK             | FCR4.0M5  | Cin=Cout=33pF  | 2.2 ~ 4.0V        |
| _         | TDK             | CCR4.0MC3 |                | 2.2 ~ 4.0V        |

\* MC type is building in load capacitior.CCR type is chip type.

# **17. RESET FUNCTION**

### **17.1 EXTERNAL RESET**

The RESET pin should be held at low for at least 2machine cycles with the power supply voltage within the operating voltage range and must be connected 0.1 uF capacitor for stable system initial-



Figure 17-1

#### **17.2 POWER ON RESET**

Power On Reset circuit automatically detects the rise of power voltage (the rising time should be within 50ms) the power voltage reaches a certain level, RESET terminal is maintained at °»L°» Level until a crystal ceramic oscillator oscillates stably. After power applies and starting of oscillation, this reset state is maintained for about oscillation cycle of 219 (about 65.5ms : at 4MHz). The execution of built-in Power On Reset circuit is as follows :

(1) Latch the pulse from Power On Detection Pulse Generator circuit, and reset Prescaler, B.I.T and B.I.T Overflow detection cir-

ization. The RESET pin contains a Schmitt trigger with an internal pull-up resistor.

cuit.

(2) Once B.I.T Overflow detection circuit is reset. Then, Prescaler starts to count.

(3) Prescaler output is inputted into B.I.T and PS10 of Prescaler output is automatically selected. If overflow of B.I.T is detected, Overflow detection circuit is set.

(4) Reset circuit generates maximum period of reset pulse from Prescaler and B.I.T.



Figure 17-2 Block Diagram of Power On Reset Circuit

tion time doesn't include OSC. Start time.

Note: Notice ; When Power On Reset, oscillator stabiliza-



Figure 17-3 Oscillator stabilization diagram



Figure 17-4 Reset Timing by Diagram

# 17.3 Low Voltage Detection Mode

# (1) Low voltage detection condition

An on board voltage comparator checks that VDD is at the required level to ensure correct operation of the device. If VDD is below a certain level, Low voltage detector forces the device into low voltage detection mode.

# (2) Low Voltage Detection Mode

There is no power consumption except stop current, stop mode release function is disabled. All I/O port is configured as input mode and Data memory is retained until voltage through external

capacitor is worn out. In this mode, all port can be selected with Pull-up resistor by Mask option. If there is no information on the Mask option sheet ,the default pull up option (all port connect to pull-up resistor ) is selected.

# (3) Release of Low Voltage Detection Mode

Reset signal result from new battery(normally 3V) wakes the low voltage detection mode and come into normal reset state. It depends on user whether to execute RAM clear routine or not.



Figure 17-5 Low Voltage vs Temperature

# (4) SRAM BACK-UP after Low Voltage Detection.



Figure 17-6 Low Voltage Detection and Protection

### (5) S/W flow chart example after Reset using SRAM Back-up



Figure 17-7 S/W Flow Chart Example for SRAM Back-

up

### 17.4 Low Voltage Indicator Register (LVIR)

Low Voltage Indication Register (LVIR) is read only Register. It is useful to display the consumption of Batteries. If VDD power level is below a cirtain level which is higher than low voltage detection level (refer to Figure 17-6), The bit of LVIR register could be set according to the VDD level sequentially. The VDD dection levels for Indication are two, that is, Bit1 and Bit0 of LVIR Register. The detection level of Bit0 is higer than Bit1.



# **18. CLOCK GENERATOR**

Clock generating circuit consists of Clock Pulse Generator (C.P.G), Prescaler, Basic Interval Timer (B.I.T) and Watch Dog

Timer. The clock applied to the Xin pin divided by two is used as the internal system clock.



Figure 18-1 Block Diagram of Clock Generator

Prescaler consists of 12-bit binary counter. The clock supplied from oscillation circuit is input to prescaler (fex). The divided

output from each bit of prescaler is provided to peripheral hard-ware.



Figure 18-2 Block diagram of Prescaler

# MagnaChip•

| fex (MHz) | 4 MHz     |         | 2 MHz     |         |
|-----------|-----------|---------|-----------|---------|
|           | frequency | period  | frequency | period  |
| ps 0      | 4 MHz     | 250 ns  | 2 MHz     | 500 ns  |
| ps 1      | 2 MHz     | 500 ns  | 1 MHz     | 1 us    |
| ps 2      | 1 MHz     | 1 us    | 500 KHz   | 2 us    |
| ps 3      | 500 KHz   | 2 us    | 250 KHz   | 4 us    |
| ps 4      | 250 KHz   | 4 us    | 125 KHz   | 8 us    |
| ps 5      | 125 KHz   | 8 us    | 62.5 KHz  | 16 us   |
| ps 6      | 62.5 KHz  | 16 us   | 31.25 KHz | 32 us   |
| ps 7      | 31.25 KHz | 32 us   | 15.63 KHz | 64 us   |
| ps 8      | 15.63 KHz | 64 us   | 7.183 KHz | 128 us  |
| ps 9      | 7.183 KHz | 128 us  | 3.906 KHz | 256 us  |
| ps 10     | 3.906 KHz | 256 us  | 1.953 KHz | 512 us  |
| ps 11     | 1.953 KHz | 512 us  | 0.976 KHz | 1024 us |
| ps 12     | 0.976 KHz | 1024 us | 0.488 KHz | 2048 us |

#### Table 18-1 ps output perio Basic Interval Timer

The HMS87C5216 and GMS81C1408 has one 8-bit Basic Interval Timer that is free-run, can not stop. Block diagram is shown in Figure 18-3. The 8-bit Basic interval timer register (BITR) is increased every internal count pulse which is divided by prescaler. Since prescaler has divided ratio by 8 to 1024, the count rate is 1/8 to 1/1024 of the oscillator frequency. As the count overflows from  $FF_H$  to  $00_H$ , this overflow causes to generate the Basic interval timer interrupt. The BITF is interrupt request flag of Basic interval timer.

When write "1" to bit BTCL of CKCTLR, BITR register is cleared to "0" and restart to count-up. The bit BTCL becomes "0" after one machine cycle by hardware.

If the STOP instruction executed after writing "1" to bit WAKE-UP of CKCTLR, it goes into the wake-up timer mode. In this mode, all of the block is halted except the oscillator, prescaler (only fxin÷2048) and Timer0.

If the STOP instruction executed after writing "1" to bit RCWDT of CKCTLR, it goes into the internal RC oscillated watchdog timer mode. In this mode, all of the block is halted except the internal RC oscillator, Basic Interval Timer and Watchdog Timer. More detail informations are explained in Power Saving Function. The bit WDTON decides Watchdog Timer or the normal 7-bit timer

**Note:** All control bits of Basic interval timer are in CKCTLR register which is located at same address of BITR (address  $EC_H$ ). Address  $EC_H$  is read as BITR, written to CKCTLR. Therefore, the CKCTLR can not be accessed by bit manipulation instruction.



Figure 18-3 Block Diagram of Basic Interval Timer



Figure 18-4 CKCTLR: Clock Control Register

# **19. ANALOG TO DIGITAL CONVERTER**

The analog-to-digital converter (A/D) allows conversion of an analog input signal to a corresponding 8-bit digital value. The A/D module has eight analog inputs, which are multiplexed into one sample and hold. The output of the sample and hold is the input into the converter, which generates the result via successive approximation.

The analog reference voltage is  $V_{DD}$ . The A/D module has two registers which are the control register ADMR and A/D result register ADDR. The ADMR register, shown in Figure 19-2, controls the operation of the A/D converter module. The port pins can be configure as analog inputs or digital I/O.

To use analog inputs, each port is assigned analog input port by setting the bit ANSEL[7:0] in RAFUNC register. And selected

the corresponding channel to be converted by setting ADS[2:0].

The processing of conversion is start when the start bit ADST is set to "1". After one cycle, it is cleared by hardware. The register ADCR contains the results of the A/D conversion. When the conversion is completed, the result is loaded into the ADCR, the A/D conversion status bit ADSF is set to "1", and the A/D interrupt flag ADIF is set. The block diagram of the A/D module is shown in Figure 19-1. The A/D status bit ADSF is set automatically when A/D conversion is completed, cleared when A/D conversion is in process. The conversion time takes maximum 30 uS (at fxin=4 MHz).



Figure 19-1 A/D Converter Block Diagram

#### HMS87C5216



Figure 19-2 A/D Converter Registers





#### **A/D** Converter Cautions

(1) Input range of AN0 to AN3

The input voltage of AN0 to AN3 should be within the specification range. In particular, if a voltage above VDD or below Vss is input (even if within the absolute maximum rating range), the conversion value for that channel can not be indeterminate. The conversion values of the other channels may also be affected.

(2) Noise countermeasures

In order to maintain 8-bit resolution, attention must be paid to noise on pins VDD and AN0 to AN3. Since the effect increases in proportion to the output impedance of the analog input source, it is recommended that a capacitor be connected externally as shown in Figure 19-4 in order to reduce noise.



#### Figure 19-4 Analog Input Pin Connecting Capacitor

(3) Pins AN0/R1[4] and AN1/R1[5] to AN3/R1[7]

The analog input pins AN0 to AN3 also function as input/output port (PORT R1 ) pins. When A/D conversion is performed with

# MagnaChip

any of pins AN0 to AN3 selected, be sure not to execute a PORT input instruction while conversion is in progress, as this may reduce the conversion resolution.

Also, if digital pulses are applied to a pin adjacent to the pin in the

process of A/D conversion, the expected A/D conversion value may not be obtainable due to coupling noise. Therefore, avoid applying pulses to pins adjacent to the pin undergoing A/D conversion.